<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>05-函数组件使用props</title>
</head>

<body>
    <!-- 准备好一个容器 -->
    <div id="test1"></div>
    <div id="test2"></div>
    <div id="test3"></div>
    <!-- 引入react核心库 -->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <!-- 引入react-dom，用于支持react操作DOM -->
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <!-- 引入babel，用于将jsx转换为js -->
    <script type="text/javascript" src="../js/babel.min.js"></script>

    <!-- 引入prop-types，用于对组件标签属性进行限制 -->
    <script type="text/javascript" src="../js/prop-types.js"></script>

    <script type="text/babel">  //此处一定要写babel
        //创建组件
        // class Person extends React.Component {

        //     constructor(props) {
        //         //构造器是否接收props，是否传递给super，取决于：是否希望在构造器中通过this访问props
        //         super(props);
        //         console.log('constructor', this.props);
        //     }

        //     //对标签属性进行类型，必要性的限制
        //     static propTypes = {
        //         name: PropTypes.string.isRequired,      //限制name必传，且为字符串
        //         gender: PropTypes.string,               //限制gender为字符串
        //         age: PropTypes.number,                  //限制age为数字
        //     }
        //     //指定默认标签属性值
        //     static defaultProps = {
        //         gender: "男",                           //gender默认值为男
        //         age: 18                                 //默认值为18
        //     }



        //     render() {

        //         const { name, age, gender } = this.props;
        //         // props是只读的
        //         // this.props.name = 'tom';         //此行代码会报错，因为props是只读的

        //         return (
        //             <ul>
        //                 <li>姓名：{name}</li>
        //                 <li>性别：{gender}</li>
        //                 <li>年龄：{age + 1}</li>
        //             </ul>
        //         )
        //     }
        // }


        function Person(props) {
            console.log(props)
            const { name, gender, age } = props;
            return (
                <ul>
                    <li>姓名：{name}</li>
                    <li>性别：{gender}</li>
                    <li>年龄：{age + 1}</li>
                </ul>
            )
        }

        //对标签属性进行类型，必要性的限制
        Person.propTypes = {
            name: PropTypes.string.isRequired,      //限制name必传，且为字符串
            gender: PropTypes.string,               //限制gender为字符串
            age: PropTypes.number,                  //限制age为数字
        }
        //指定默认标签属性值
        Person.defaultProps = {
            gender: "男",                           //gender默认值为男
            age: 18                                 //默认值为18
        }
        //渲染组件到页面
        ReactDOM.render(<Person name="jerry" gender="女" age={18} />, document.querySelector('#test1'));

    </script>
</body>

</html>